<?php
/**
 * JwtGenerator.php
 * phpstorm_company_name_str - phpstorm_company_product_name
 * ***************************************************************************************************************************
 * 版权声明: Copyright ©2019 phpstorm_company_name_str All rights reserved
 * 官方网站: phpstorm_company_product_url
 * 许可声明: 这不是一个自由软件！您只能在购买源代码后或者经 phpstorm_company_name_str 官方授权的前提下对程序代码进行修改和使用，
 * 任何企业或个人都不得在源代码上以任何形式任何目的的再次发布和销售以及镜像或复制,包括但不限于已购买源代码和官方授权者。
 * 警 告  : 如若您或贵司未经正式购买渠道获得授权，请立即停止侵权行为，我们已经委派 phpstorm_company_auth_legal 作为我们侵权
 * 起诉的法律代表，还请您或贵司尊重商业版权以及劳动成果，自觉停止侵权行为。您也可匿名举报侵权行为，一旦您的举报被证实，我们
 * 将会以本版本零售价的 phpstorm_company_product_percent_money% 现金给您，以便作为您的辛苦奖励。同时，我们也将竭尽全力保证您的隐私安全。举报邮箱: phpstorm_company_product_report_mail
 * 协议约定: 本产品遵守 << phpstorm_company_product_protocol >> 的约束,您或贵司也可以访问 phpstorm_company_product_protocol 了解更多详情信息。
 * 致 谢  : 感谢您或贵司对我们产品的支持和热爱，我们将不定期对本产品进行更新和修复bug。还请您和贵司多多指导。更多问题资讯请访问
 * phpstorm_company_product_help_url ,如果您正在对此版本进行二次开发，提bug或者需求可以发送到@author邮箱,或者提交工单。
 * 工单地址是: phpstorm_company_product_ticket_url 我们将尽快为您提出合理的解决方案。
 * 其 他  : 您或贵司也可以登录 phpstorm_company_product_doc_url 查看相关的文档资料以及FAQ！
 * ***************************************************************************************************************************
 * @product ctmoncms
 * @desc
 * @author justary <justary@126.com>
 * @date 2024/06/24 10:07
 * @version phpstorm_company_product_version
 * @copyright phpstorm_company_product_copyright
 */

/**
 * @package app\data\components
 *
 * @filesource JwtGenerator.php
 * @author justary <justary@126.com>
 * @date 2024/06/24 10:07
 * @link phpstorm_product_licence
 * @version phpstorm_company_product_version
 * @copyright phpstorm_company_product_copyright
 */


namespace app\data\components;


use Firebase\JWT\BeforeValidException;
use Firebase\JWT\ExpiredException;
use Firebase\JWT\JWT;
use Firebase\JWT\Key;
use Firebase\JWT\SignatureInvalidException;
use think\route\Rule;

class JwtGenerator
{
    public static function generatorJwtToken(string $key,$payload): string {
      //使用firebase/php-jwt生成jwt token
      $jwt = JWT::encode($payload,$key,'HS256');
      $decoded = JWT::decode($jwt, new Key($key, 'HS256'));
      if($decoded->iss){
        return $jwt;
      }
      echo 'generator access token failure';
    }

  /**
   * subject content
   *
   * @param string $key
   * @param string $jwt
   * @return array
   * @static
   * @author justary  <justary@126.com>
   * @date 2024-06-24 16:19
   */
    public static function checkJwtToken(string $key,string $jwt): array
    {
      // 验证 JWT
      try {
        $decode = JWT::decode($jwt, new Key($key, 'HS256'));
        if($decode->iss && $decode->aud){
          $result = ['state'=>true];
        }else{
          $result = ['state'=>false,'msg' => 'INCORRECT_ACCESS_TOKEN'];
        }
      } catch (ExpiredException $e){
        $result = ['state'=>false,'msg'=>'ACCESS_TOKEN_EXPIRE'];
      } catch (BeforeValidException $e){
        $result = ['state'=>false,'msg'=>'ACCESS_TOKEN_NOT_EMPTY'];
      } catch (SignatureInvalidException $e){
        $result = ['state'=>false,'msg'=>'INCORRECT_ACCESS_TOKEN'];
      }
      return $result;
    }
}
